

### What is claimed is:

1. A method for recovering phase information comprising:
  2. over-sampling data transmitted at a first frequency using a clock at a second frequency to obtain groups of n samples;
  3. storing a plurality of m of said groups of n samples;
  4. outputting said plurality of m of said groups of n samples simultaneously at a clock frequency which is said second frequency divided by m.
2. 2. A method according to claim 1 and further including:
  3. using said plurality of m of said groups of n samples to detect transitions in said data; and
  4. maintaining an historical record of said transitions.
3. 3. A method according to claim 2 and further including:
  4. using said historical record to determine a phase of said second frequency that is nearly centered in the middle of a bit time of said data at said first frequency.
4. 4. A method according to claim 3 wherein said step of determining a phase comprises:
  5. a. Oring each history bit with the following bit to obtain a highest byte;
  6. b. Oring each bit in said highest byte with a bit on either side to obtain a second highest byte;
  7. c. Oring each bit in said second highest byte with a bit on either side to obtain a third highest byte; and
  8. d. determining the highest level byte which has two or fewer zeros and outputting:
    9. i. the phase of the sole remaining zero if there is only one zero;
    10. ii. the phase of the latest zero if an adjacent pair remains;
    11. iii. an error indication if two non-adjacent zeros remain.

1       5.     A method according to claim 4 and further including limiting the maximum phase  
2     change to plus or minus one sample phase.

1       6.     A method according to claim 3 and further including:  
2                 using said historical record to select bits of said data at said first frequency and  
3                 output said bits in groups of generally m valid bits at a time at said second frequency  
4                 divided by m.

1       7.     A method according to claim 6 wherein, due to the difference in said first and  
2     second frequency a draft occurs causing said phase to select m+1 or m-1 bits of data and  
3     further including:  
4                 outputting either m, m+1 or m-1 valid bits; and  
5                 using said historical record to provide an indication of how many bits are being  
6     output.

1       8.     A method according to claim 7 wherein said step of providing an indication of how  
2     many valid bits are being output comprises:  
3                 a.     determining whether the current phase selection is different from the  
4                 previous phase selection and if not, indicating that bits m:1 are valid;  
5                 b.     if the current phase selection is different from the previous phase selection,  
6                 determining if the current phase selection wraps around from the previous  
7                 phase selection and if not, indicating that bits m:1 are valid;  
8                 c.     if the current phase selection wraps around from the previous phase  
9                 selection determining if it wraps around from the latest to earliest sample  
10                 phase, and, if so, indicating that bits (m-1):1 are valid; and  
11                 d.     if the current phase selection wraps around from the previous phase  
12                 selection determining if it wraps around from the earliest to latest sample  
13                 phase, and, if so, indicating that bits m:0 are valid.

1       9.     A method for recovering phase information comprising:

00026588-00026589-00026590

1           over-sampling data transmitted at a first frequency using a clock at a second  
2           frequency, n times per bit time to obtain n samples;  
3           using said n samples to detect the transitions between two logic levels in said  
4           transmitted data and provide n edge results which are at one logic level to indicate a  
5           transition and the other logic level to indicate no transition;  
6           storing, in sequence, at said second clock frequency, m sets of said n samples; and  
7           outputting said m times n samples at a clock frequency which is said second  
8           frequency divided by m.

1       10.    A method according to claim 9 and further including maintaining a running history  
2       of said edge results comprising:  
3           combining in n separate m input OR gates the m times n samples, each gate having  
4           as inputs the m of said samples in the same relative position in each of said m sets;  
5           using the outputs of said n OR gates to set p sets of byte registers, each having n  
6           registers; and  
7           resetting said p byte registers in a wrap around sequence.

1       11.    A method according to claim 10 and further including:  
2           using outputs of said byte registers to determine a phase of said second frequency  
3           that is nearly centered in the middle of a bit time of said data at said first frequency.

1       12.    A method according to claim 11 wherein said step of determining a phase  
2       comprises:  
3           a.     Oring each history bit with the following bit to obtain a highest byte;  
4           b.     Oring each bit in said highest byte with a bit on either side to obtain a  
5           second highest byte;  
6           c.     Oring each bit in said second highest byte with a bit on either side to obtain  
7           a third highest byte; and  
8           d.     determining the highest level byte which has two or fewer zeros and  
9           outputting:

- 1                   i.     the phase of the sole remaining zero if there is only one zero;
- 2                   ii.    the phase of the latest zero if an adjacent pair remains;
- 3                   iii.    an error indication if two non-adjacent zeros remain.

1 13. A method according to claim 12 and further including limiting the maximum phase  
2 change to plus or minus one sample phase.

1 14. A method according to claim 13 and further including:  
2 using said phase to select bits of said data at said first frequency and output said bits  
3 in groups of generally  $m$  at a time at said second frequency divided by  $m$ .

1 15. A method according to claim 14 wherein, due to the difference in said first and  
2 second frequency a drift occurs causing said phase to select  $m+1$  or  $m-1$  bits of data and  
3 further including:

4 outputting either  $m$ ,  $m+1$  or  $m-1$  bits; and  
5 using said phase information to provide an indication of how many bits are being  
6 output.

1 16. A method according to claim 15 wherein said step of providing an indication of  
2 how many bits are being output comprises:

3           a. determining whether the current phase selection is different from the  
4            previous phase selection and if not, indicating that bits m:1 are valid;  
5           b. if the current phase selection is different from the previous phase selection,  
6            determining if the current phase selection wraps around from the previous  
7            phase selection and if not, indicating that bits m:1 are valid;  
8           c. if the current phase selection wraps around from the previous phase  
9            selection determining if it wraps around from the latest to earliest sample  
10           phase, and, if so, indicating that bits m-1:1 are valid; and

1           d. if the current phase selection wraps around from the previous phase  
2           selection determining if it wraps around from the earliest to latest sample  
3           phase, and, if so, indicating that bits.m:0 are valid.

1 17. Apparatus for recovering phase information comprising:  
2 an over-sampler having an input for data transmitted at a first frequency and n  
3 sampling clock inputs each at a second frequency but different phase each clock shifted in  
4 phase from an adjacent clock by  $360/n$  degrees and providing n sample outputs; and  
5 a sample word register having inputs coupled to said n sample outputs, storing m  
6 sets of said n sample outputs at said second frequency and outputting said m sets of n  
7 sample outputs at a frequency equal to said frequency divided by m.

1 18. Apparatus according to claim 18 and further including an edge detector using said  
2 m sets of n sample outputs to detect the transitions between two logic levels in said  
3 transmitted data and provide m sets of n edge results which are at one logic level to  
4 indicate a transition and another logic level to indicate no transition.

19. Apparatus according to claim 18 wherein said edge detectors comprise a plurality of  
XOR gates.

4 20. Apparatus according to claim 19 and further including:  
5 n separate m input OR gates, each gate having as inputs the m of said n edge results  
6 in the same relative position in each of said m sets of n edge results; and  
7 p sets of n-bit byte registers, the outputs of each of said n OR gates being a set input  
8 to one of the n bits in each of said p byte registers.

1 21. Apparatus according to claim 20 and further including a packet state machine  
2 providing reset inputs to said byte registers.

Docket No.: 2207/9048

1 22. Apparatus according to claim 21 and further including:  
2       phase selection logic having the outputs of said byte registers as inputs and  
3       outputting a signal indicating a phase of said second frequency that is nearly centered in the  
4       middle of a bit time of said data at said first frequency.

1 23. Apparatus according to claim 22 and further including:  
2       a data selector register having a data input from said sample register and the output  
3       of said phase selection logic as a select input to select bits of said data at said first  
4       frequency and output said bits in groups of generally m valid bits at a time at said second  
5       frequency divided by m.

1 24. Apparatus according to claim 23 wherein due to the difference in said first and  
2       second frequency a drift occurs casing said data selector register to output m+1 or m-1  
3       valid bits of data and further including:  
4       a bit count state machine providing as an output an indication of how many valid  
5       bits are being output by said data selector register.

00626000000000000000000000000000